-
-
Notifications
You must be signed in to change notification settings - Fork 106
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Implement Atmos Version Check Configuration #844
Conversation
Update documentation here: https://atmos.tools/cli/ Also, here: https://atmos.tools/cli/commands/version |
Caution Review failedThe pull request is closed. 📝 Walkthrough📝 WalkthroughWalkthroughThe pull request introduces a comprehensive version checking mechanism for the Atmos CLI. A new configuration section in Changes
Assessment against linked issues
Possibly related PRs
Suggested Reviewers
Tip CodeRabbit's docstrings feature is now available as part of our Early Access Program! Simply use the command 📜 Recent review detailsConfiguration used: .coderabbit.yaml 📒 Files selected for processing (4)
Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media? 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
Documentation and Community
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 6
🧹 Outside diff range and nitpick comments (3)
pkg/config/cache.go (1)
66-80
: ConsolidateSaveCache
functions for clarityThere are two functions,
SaveCache2
andSaveCache
, performing similar tasks. Merging them or renaming for clarity could improve maintainability.Also applies to: 82-94
cmd/root.go (1)
21-21
: Consider scoping the configuration more tightlyWhile this follows the existing pattern, consider passing the configuration as a parameter to functions that need it, rather than relying on a global variable. This would improve testability and make dependencies more explicit.
pkg/config/config.go (1)
85-91
: Document the version check configuration parametersThe version check configuration looks good, but please add comments explaining:
- The units for the timeout value (milliseconds?)
- Valid values for the frequency field
- The implications of these settings
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
⛔ Files ignored due to path filters (1)
go.sum
is excluded by!**/*.sum
📒 Files selected for processing (10)
atmos.yaml
(1 hunks)cmd/cmd_utils.go
(2 hunks)cmd/helmfile.go
(1 hunks)cmd/root.go
(2 hunks)cmd/terraform.go
(1 hunks)go.mod
(1 hunks)pkg/config/cache.go
(1 hunks)pkg/config/config.go
(1 hunks)pkg/config/utils.go
(1 hunks)pkg/schema/schema.go
(2 hunks)
🧰 Additional context used
🪛 golangci-lint (1.62.2)
pkg/config/cache.go
39-39: Error return value of lock.Unlock
is not checked
(errcheck)
🔇 Additional comments (5)
pkg/config/cache.go (1)
96-108
: 🛠️ Refactor suggestion
Add a warning for unsupported frequency values
We should inform users when an unsupported frequency is provided, and we're defaulting to 'daily'.
You might add a warning like:
default:
interval = 86400 // default daily
+ fmt.Printf("Warning: Unsupported frequency '%s', defaulting to 'daily'\n", frequency)
cmd/root.go (1)
89-95
: LGTM! Error handling improvements look solid.
The separation of error handling for version commands vs. other commands is well implemented. The code properly handles the case where configuration is not found but version information is still needed.
Let's verify all version-related command handlers are consistent:
✅ Verification successful
Version command handling is properly implemented and consistent
The verification confirms that:
isVersionCommand()
correctly checks for the "version" argument- Version command is properly registered with cobra framework
- Error handling in root.go appropriately uses
isVersionCommand()
to handle configuration errors differently for version commands
The implementation maintains consistency across all version-related functionality.
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Search for version command handlers to ensure consistent error handling
rg -p "isVersionCommand|version command" cmd/
Length of output: 179
Script:
#!/bin/bash
# Let's check the implementation of isVersionCommand and its usage context
ast-grep --pattern 'func isVersionCommand() bool {
$$$
}'
# Also check the version command registration
rg -p "version.*Command" cmd/ -A 5
Length of output: 492
go.mod (1)
19-19
: LGTM! Good choice for file locking.
The gofrs/flock
library is a solid choice for implementing file locking in the cache mechanism. It's well-maintained and widely used.
atmos.yaml (1)
319-323
: LGTM! Well-structured version check configuration.
The configuration follows best practices with sensible defaults:
- Version check enabled by default
- 1-second timeout is reasonable
- Daily frequency strikes a good balance
pkg/schema/schema.go (1)
29-29
: LGTM! Well-designed schema for version configuration.
The schema changes are clean and follow Go best practices:
- Proper struct tags for serialization
- Optional fields marked with
omitempty
- Clear separation of concerns between
Version
andVersionCheck
types
Also applies to: 131-139
fe80497
to
0f79d1c
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 1
🧹 Outside diff range and nitpick comments (3)
pkg/config/cache.go (1)
96-108
: Enhance update frequency validationThe function should provide better feedback for unsupported intervals.
func ShouldCheckForUpdates(lastChecked int64, frequency string) bool { now := time.Now().Unix() var interval int64 switch frequency { case "daily": interval = 86400 case "weekly": interval = 604800 default: + u.LogWarning(schema.CliConfiguration{}, fmt.Sprintf("Unsupported update frequency '%s', defaulting to daily", frequency)) interval = 86400 // default daily } return now-lastChecked >= interval }
cmd/root.go (2)
89-96
: Improve error handling specificityThe error handling could be more specific about the type of configuration error encountered.
var initErr error cliConfig, initErr = cfg.InitCliConfig(schema.ConfigAndStacksInfo{}, false) if initErr != nil && !errors.Is(initErr, cfg.NotFound) { if isVersionCommand() { - u.LogTrace(schema.CliConfiguration{}, fmt.Sprintf("warning: CLI configuration 'atmos.yaml' file not found. Error: %s", initErr)) + u.LogTrace(schema.CliConfiguration{}, fmt.Sprintf("warning: Failed to initialize CLI configuration. Error: %s", initErr)) } else { u.LogErrorAndExit(schema.CliConfiguration{}, initErr) }
99-106
: Consider deferring help function setupThe help function setup could be deferred until after all initialization is complete to ensure proper configuration state.
Consider moving the help function setup after the custom commands processing to ensure all configuration is properly loaded.
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
⛔ Files ignored due to path filters (1)
go.sum
is excluded by!**/*.sum
📒 Files selected for processing (10)
atmos.yaml
(1 hunks)cmd/cmd_utils.go
(2 hunks)cmd/helmfile.go
(1 hunks)cmd/root.go
(2 hunks)cmd/terraform.go
(1 hunks)go.mod
(1 hunks)pkg/config/cache.go
(1 hunks)pkg/config/config.go
(1 hunks)pkg/config/utils.go
(1 hunks)pkg/schema/schema.go
(2 hunks)
🚧 Files skipped from review as they are similar to previous changes (6)
- go.mod
- pkg/config/config.go
- atmos.yaml
- cmd/helmfile.go
- pkg/config/utils.go
- pkg/schema/schema.go
🧰 Additional context used
🪛 golangci-lint (1.62.2)
pkg/config/cache.go
39-39: Error return value of lock.Unlock
is not checked
(errcheck)
🔇 Additional comments (7)
cmd/terraform.go (1)
39-39
: Verify cliConfig initialization before use
The usage of cliConfig
here could lead to runtime issues if not properly initialized.
#!/bin/bash
# Check if cliConfig is properly initialized before use
ast-grep --pattern 'cliConfig = $_'
pkg/config/cache.go (1)
33-41
:
Handle lock.Unlock() errors
The deferred unlock operation should handle potential errors.
- defer lock.Unlock()
+ defer func() {
+ if unlockErr := lock.Unlock(); unlockErr != nil {
+ err = errors.Wrap(unlockErr, "failed to release lock")
+ }
+ }()
Likely invalid or redundant comment.
🧰 Tools
🪛 golangci-lint (1.62.2)
39-39: Error return value of lock.Unlock
is not checked
(errcheck)
cmd/cmd_utils.go (5)
10-10
: LGTM! Import addition is appropriate.
The time
package import is necessary for handling cache timestamps.
436-439
: LGTM! Configuration check is well-implemented.
Early return if version checking is disabled provides clean control flow.
482-485
: LGTM! Clean implementation of help message function.
Good separation of concerns by delegating version check to the new function.
470-479
:
Use semantic versioning for version comparison.
String comparison of versions can lead to incorrect results. For example, "10.0.0" would be considered less than "9.0.0".
Previous suggestion still applies:
+import "github.com/hashicorp/go-version"
+latestVer, err := version.NewVersion(latestVersion)
+if err != nil {
+ u.LogTrace(cliConfig, fmt.Sprintf("Failed to parse latest version: %s", err))
+ return
+}
+currentVer, err := version.NewVersion(currentVersion)
+if err != nil {
+ u.LogTrace(cliConfig, fmt.Sprintf("Failed to parse current version: %s", err))
+ return
+}
-if latestVersion != currentVersion {
+if latestVer.GreaterThan(currentVer) {
474-478
:
Update cache timestamp regardless of version comparison.
The cache timestamp should be updated after every check, not just when versions differ, to properly respect the frequency settings.
Move the cache update outside the version comparison:
if latestVersion != currentVersion {
u.PrintMessageToUpgradeToAtmosLatestRelease(latestVersion)
}
+// Update the cache to mark the current timestamp
+cacheCfg.LastChecked = time.Now().Unix()
+if saveErr := cfg.SaveCache(cacheCfg); saveErr != nil {
+ u.LogWarning(cliConfig, fmt.Sprintf("Unable to save cache: %s", saveErr))
+}
On the version command, I think we should add a --check argument so the user can force the behavior to check for the latest version, even if the cache has a recent check. |
@osterman the version command is the only one that is not checking for cache right now , nor updates it, and displays the box all the time. So it should check for cache too and use --check to still display the box? |
Does the version command respect the version check config settings? We want to make sure that it does. |
@osterman thanks, sure, thank you so much for the clarifications. Have pushed the changes as requested. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 1
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (3)
cmd/cmd_utils.go
(2 hunks)cmd/version.go
(2 hunks)pkg/config/utils.go
(1 hunks)
🚧 Files skipped from review as they are similar to previous changes (1)
- pkg/config/utils.go
🔇 Additional comments (3)
cmd/cmd_utils.go (3)
470-471
: Use semantic versioning for version comparison
The current string comparison of versions could lead to incorrect results.
475-480
: LGTM: Cache timestamp update implementation
Great implementation of updating the cache timestamp regardless of whether an update is found. This ensures proper frequency control of version checks.
432-481
: LGTM: Well-structured version check implementation
The implementation is thorough and handles all edge cases:
- Respects configuration settings
- Handles cache loading errors gracefully
- Implements proper frequency control
- Updates cache timestamp appropriately
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 1
🧹 Outside diff range and nitpick comments (3)
website/docs/cli/commands/version.mdx (2)
23-28
: WARRIOR! Let's polish this documentation for clarity!The text needs some refinement to maintain our high standards:
-This will show the CLI version. The frequency with which the update box message in version is shown is configured in atmos.yaml. -There are two options daily and weekly. The default value is set to daily. -It is also possible to turn it off in atmos.yaml file by switching enable to false. -Or set an env variable ATMOS_VERSION_CHECK_ENABLED to false, -this overriders the config's settting. +This will show the CLI version. The frequency of the update box message is configured in the atmos.yaml file. +There are two options: daily and weekly. The default value is set to daily. +You can disable this feature in the atmos.yaml file by setting `enable: false`, +or by setting the environment variable `ATMOS_VERSION_CHECK_ENABLED=false`, +which overrides the config's setting.🧰 Tools
🪛 LanguageTool
[uncategorized] ~25-~25: Possible missing comma found.
Context: ...configured in atmos.yaml. There are two options daily and weekly. The default value is ...(AI_HYDRA_LEO_MISSING_COMMA)
[grammar] ~27-~27: The singular determiner ‘this’ may not agree with the plural noun ‘overriders’. Did you mean “these”?
Context: ... ATMOS_VERSION_CHECK_ENABLED to false, this overriders the config's settting. ```...(THIS_NNS)
30-35
: STAND STRONG! Let's enhance the --check flag documentation!The explanation could be more precise:
-The version command supports --check flag. -It will show the update box message irrespectively of the config settings. +The version command supports the `--check` flag, which forces the display of the update box message +regardless of your configuration settings.website/docs/cli/commands/help.mdx (1)
Line range hint
23-28
: STRENGTHEN OUR DOCUMENTATION WITH A CONFIGURATION EXAMPLE!Both documentation files would benefit from showing an actual configuration example:
Consider adding this configuration example to both files:
settings: version: enabled: true # Enable/disable version check frequency: daily # Options: daily, weekly timeout: 1000 # Timeout in millisecondsThis will help warriors understand exactly how to configure these settings in their
atmos.yaml
file!Also applies to: 15-20
🧰 Tools
🪛 LanguageTool
[uncategorized] ~17-~17: A comma might be missing here.
Context: ...configured in atmos.yaml. There are two options daily and weekly. The default value is ...(AI_EN_LECTOR_MISSING_PUNCTUATION_COMMA)
[uncategorized] ~18-~18: You might be missing the article “the” here.
Context: ... It is also possible to turn it off in atmos.yaml file by switching enable to false. Or ...(AI_EN_LECTOR_MISSING_DETERMINER_THE)
[grammar] ~19-~19: The singular determiner ‘this’ may not agree with the plural noun ‘overriders’. Did you mean “these”?
Context: ... ATMOS_VERSION_CHECK_ENABLED to false, this overriders the config's settting. ``...(THIS_NNS)
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (2)
website/docs/cli/commands/help.mdx
(1 hunks)website/docs/cli/commands/version.mdx
(1 hunks)
🧰 Additional context used
🪛 LanguageTool
website/docs/cli/commands/help.mdx
[uncategorized] ~17-~17: A comma might be missing here.
Context: ...configured in atmos.yaml. There are two options daily and weekly. The default value is ...
(AI_EN_LECTOR_MISSING_PUNCTUATION_COMMA)
[uncategorized] ~18-~18: You might be missing the article “the” here.
Context: ... It is also possible to turn it off in atmos.yaml file by switching enable to false. Or ...
(AI_EN_LECTOR_MISSING_DETERMINER_THE)
[grammar] ~19-~19: The singular determiner ‘this’ may not agree with the plural noun ‘overriders’. Did you mean “these”?
Context: ... ATMOS_VERSION_CHECK_ENABLED to false, this overriders the config's settting. ``...
(THIS_NNS)
website/docs/cli/commands/version.mdx
[uncategorized] ~25-~25: Possible missing comma found.
Context: ...configured in atmos.yaml. There are two options daily and weekly. The default value is ...
(AI_HYDRA_LEO_MISSING_COMMA)
[grammar] ~27-~27: The singular determiner ‘this’ may not agree with the plural noun ‘overriders’. Did you mean “these”?
Context: ... ATMOS_VERSION_CHECK_ENABLED to false, this overriders the config's settting. ```...
(THIS_NNS)
@osterman, thanks yes, it does, its just does not show the box because the timestamp is already there and time has not elapsed. atmos version --check does not intefere with the cache at all though (does not update timstamp either, if that ok?) |
Sounds like the right implementation. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
thanks @Listener430
These changes were released in v1.127.0. |
what
This PR contains
Here are some comments/illustrations
before for non --help command the update box untintendently appear
after the fix
additionally added config in atmos.yaml
with defualt config deined as
and env variable to disable everuthing if user does not want this feature displayed at all except version in config/utils.go
after the first --help run on any command box appears: example terrraform
then atmos/cache.yaml is generated with time stamp
and the box disspaers until the time interval exceed specidifed in config
why
references
Link to the ticket - https://linear.app/cloudposse/issue/DEV-2815/atmos-version-check-configuration
Summary by CodeRabbit
Release Notes
New Features
atmos.yaml
.--check
flag for theversion
command to force update checks.Bug Fixes
Documentation
version
command documentation with details on configurable update check frequency and usage examples.atmos.yaml
.Chores
.gitignore
for.atmos/cache.yaml
.